-
Notifications
You must be signed in to change notification settings - Fork 2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
cpu/stm32l0,l1: Fix ADC initialization order #21011
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks goood to me!
Please squash directly - I trust your testing. |
c70b776
to
0485824
Compare
@crasbe: if you provide test instruction it is nice if you tell what test you are taking about ( added that info in your message) I usually just include the command-line e.g.:
other people use the |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I was a bit confused by ADC_<something>
vs ADC_<something>_Msk
seem like one is alias for the other e.g.:
cmsis/l1/Include/stm32l152xd.h
1000:#define ADC_CR1_RES_Msk (0x3UL << ADC_CR1_RES_Pos) /*!< 0x03000000 */
1001:#define ADC_CR1_RES ADC_CR1_RES_Msk
using only one ( I would prefer _Msk, i think these files before the pr prefer the one without ) would improve readability
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
the two marked snipetes use msk an no msk in opposite roles
testing and (un)setting
seems like ARM CMSIS also prefers _Pos and _Msk (in their periph example(s) is no define without)
https://arm-software.github.io/CMSIS_6/latest/Core/group__peripheral__gr.html
https://arm-software.github.io/CMSIS_5/Core_A/html/group__peripheral__gr.html#ga139b6e261c981f014f386927ca4a8444
I just looked at the other code in the file and it does not use Likewise for the additions in my other PR #20971. Only the code introduced by me uses the |
I think either is ok (I would just prefer that there is one), diverting from cmsis isn't a problem as long a the manufacturer keeps doing that (microchip just removed their extra (as in: I could not find them in the cmsis manual) bitfield structs) to me the _Msk variant is a little more telling what it actually is, but the current file make little to no use of _Msk. i might have missed something in cmsis that defines the non _Msk values but i did not see it |
@kfessel Can I resolve the conversations and squash the fixups? |
yes |
Co-authored-by: benpicco <[email protected]>
a8acff0
to
17ee40d
Compare
Thanks for this! I'll give Ben and Karl a bit of time to react before hitting merge. |
Thanks everyone for working with me on this. Even though it was a small change, I still learned a lot :) |
Contribution description
Most of this PR is already described in #20780.
The STM32L0 was enabled before the resolution bits were set, but any access to configuration registers is prohibited (and seemingly ignored by the microcontroller). Therefore, the resolution set in
adc_sample
was not actually applied and the resolution was always 12-bit.The same issue was present in the STM32L1, however this ADC hardware implementation does not seem to ignore configuration register calls (even though they are prohibited when the ADC is on). However, the resolution bits were not masked in the configuration register before setting the new resolution, leading to the resolution being stuck at 6-bit (0b11). The resolution was only OR-ed to the register.
Testing procedure
For convenience you can change the test application (
tests/periph/adc
) to print all resolution values at once, as described in #20780 (comment).Due to the issue described in #21010, I recommend flashing the NUCLEO-L152RE board with the Mass Storage Driver of the ST-Link or doing a powercycle (unplug and plug the USB cable back in) after flashing. This issue is not related to these changes.
You can connect one of the A0 to A5 pins of the Nucleo to +3.3V and observe the output.
tl;dr: The output should look something like this, when the channel is maxed out on all implemented bit sizes. The two
-1
at the end show that the 14-bit and 16-bit resolution is not implemented.Nucleo-L073RZ Master:
Nucleo-L073RZ this PR:
Nucleo-L152RE Master:
Nucleo-L152RE with the fixes applied:
Issues/PRs references
This PR is a requirement for #20971, otherwise the changes in that PR can't be tested.